package org.jsola.hr.service;

import org.jsola.core.Page;
import org.jsola.core.service.IService;
import org.jsola.hr.dao.ICrmOperationRecordDAO;
import org.jsola.hr.dto.CrmOperationRecordAddDTO;
import org.jsola.hr.dto.CrmOperationRecordUpdateDTO;
import org.jsola.hr.entity.CrmOperationRecordDO;
import org.jsola.hr.query.CrmOperationRecordQuery;
import org.jsola.hr.vo.CrmOperationRecordListVO;
import org.jsola.hr.vo.CrmOperationRecordVO;
import org.jsola.user.core.TokenUser;

import java.util.List;


/**
 * 操作记录表
 *
 * @author zhr
 */
public interface ICrmOperationRecordService extends IService<ICrmOperationRecordDAO, CrmOperationRecordDO> {

    /**
     * 新增操作记录表
     * @param crmOperationRecordAddDTO 新增操作记录表DTO
     * @param tokenUser 当前用户
     * @return 操作记录表详情信息
     */
    CrmOperationRecordVO save(CrmOperationRecordAddDTO crmOperationRecordAddDTO, TokenUser tokenUser);

    /**
     * 修改操作记录表
     * @param crmOperationRecordUpdateDTO 修改操作记录表DTO
     * @param tokenUser 当前用户
     * @return 更新数量
     */
    int update(CrmOperationRecordUpdateDTO crmOperationRecordUpdateDTO, TokenUser tokenUser);


    /**
     * 批量删除操作记录表，物理删除，更新is_valid字段，从回收站删除
     * @param tokenUser 当前用户
     * @param crmOperationRecordIds 操作记录表id
     * @return 删除数量
     */
    int deleteByIds(TokenUser tokenUser, String...crmOperationRecordIds);

    /**
     * 根据操作记录表id查找
     * @param crmOperationRecordId 操作记录表id
     * @param siteId 所属站点id
     * @return 操作记录表详情信息
     */
    CrmOperationRecordVO selectById(String crmOperationRecordId, String siteId);

    /**
     * 查询操作记录表
     * @param crmOperationRecordQuery 查询条件
     * @param siteId 所属站点id
     * @return 操作记录表列表信息
     */
    List<CrmOperationRecordListVO> select(CrmOperationRecordQuery crmOperationRecordQuery, String siteId);

    /**
    * 查询操作记录表记录数
    * @param crmOperationRecordQuery 查询条件
    * @param siteId 所属站点id
    * @return 操作记录表记录数
    */
    int selectCount(CrmOperationRecordQuery crmOperationRecordQuery, String siteId);

    /**
     * 分页查询操作记录表
     * @param crmOperationRecordQuery 查询条件
     * @param siteId 所属站点id
     * @return 操作记录表列表信息
     */
    Page<CrmOperationRecordListVO> selectPage(CrmOperationRecordQuery crmOperationRecordQuery, String siteId);


    /**
     * 根据操作记录表id查找
     * @param crmOperationRecordId 操作记录表id
     * @param siteId 所属站点id
     * @return 操作记录表
     */
    CrmOperationRecordDO selectDOById(String crmOperationRecordId, String siteId);

    /**
     * 查询操作记录表
     * @param crmOperationRecordQuery 查询条件
     * @param siteId 所属站点id
     * @return 操作记录表列表
     */
    List<CrmOperationRecordDO> selectDO(CrmOperationRecordQuery crmOperationRecordQuery, String siteId);
}


